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Preliminary 


Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 


This document contains errata and design notes that 
affect designs using the PPC405EP Rev 1.1 (PVR 
0x51210950). Each erratum includes an overview, a 
description of the system impact and a description of 
possible work-around(s). Design notes cover items 
that are not considered errata but need a description 
beyond what is provided in published documenta- 
tion. Refer to Tables 1 and 2 for a list of errata and 
design notes. 


Errata are organized by item designator in alphabet- 
ical order. The item designator consists of an 
acronym for the affected functional unit and a 
numeric value. The numeric values assigned to 
errata and design notes are not necessarily consec- 
utive. 


List of Functional Unit Acronyms: 


* CHIP Errata particular to the chip imple- 
mentation 

* CPU PPC405D4V6 processor core 

« DMA DMA controller 

* EBC External Peripheral Bus Controller 

* EMAC EMAC controller 

* GPIO General Purpose I/O controller 

* IIC IC controller 

« MAL MAL controller 

* OPBA On Chip Peripheral Bus Arbiter 

*« PCI PCI controller 

« PLB Processor Local Bus Arbiter 

* POB On Chip Peripheral Bus Bridge 

* SDRAM SDRAM controller 

* UART UART controller 


« UIC Universal Interrupt Controller 


Category definitions: 


Errata are classified according to system impact and 
the availability of a work-around. 


1. Major impact, no work-around is available. A 
problem is said to have a major impact if it 
results in a system crash, a hard failure, an 
unrecoverable soft failure, significant perfor- 
mance degradation, or the storage of incorrect 
data. 


2. Major impact, work-around is impractical to 
implement, or a substantial risk of encountering 
the same or additional problems, including per- 
formance issues, exist after the work-around is 
implemented. 


3. Major impact, work-around available. Applica- 
tion of the work-around either eliminates the 
problem, or reduces it to a minor impact issue. 


4. Minor impact, no work-around is available. Minor 
impact problems result in slight to moderate per- 
formance degradation, or are a functional vari- 
ance from specification. 


5. Minor impact, work-around is available. Minor 
impact problems result in slight to moderate per- 
formance degradation, or are a functional vari- 
ance from specification. 


6. Design enhancement. 
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Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 
Errata Summary 
Table 1. Errata Summary 
Date First 
Item Category Description Docu- remy 
mented P 
CPU_121 5 The iccci instruction may errantly cause a Data TLB Exception. 4/19/99 4/19/99 
Virtual memory marked as non-executable storage (storage attribute EX=0) can 
GRUNT 2 be loaded into the instruction cache using the icbt instruction. ote weno 
When in real mode, the 405 core may errantly make speculative instruction 
Cel iee 3 fetches from guarded storage. oy eeay 
Incorrect real mode attributes may be used when accessing the last instruction in 
CPU_197 3 a 128 MB region. 11/17/00 11/17/00 
icbt instructions executed with data relocation enabled may cause incorrect 
CPU_208 il instruction execution if the icbt misses in the UTLB or does not have permission 8/21/01 8/21/01 
to access the page. 
CPU_213 3 Incorrect data may be flushed from the data cache. 2/21/03 5/15/03 
EMAC_5 4 The EMAC constantly transmits a preamble pattern on the MIl interface. 3/25/02 1/29/03 
EMAC_7 5 Signal Quality Error (SQE) occasionally reported incorrectly during SQE test. 6/10/02 6/10/02 
EMAC_8 5 Soft Reset may not reset all logic in the EMAC 5/7/03 5/15/03 
EMAC_9 4 Integrated Flow Control Mechanism may not function correctly 5/7/03 5/15/03 
EMAC_10 4 Octet Counter Registers may not record an accurate count 5/7/03 5/15/03 
PCI_18 3 Executing code from PCI address space may hang the CPU. 2/23/01 2/23/01 
PCI 24 { The PCl Bridge Controller does not detect a parity error (PCIPErr) asserted by a 2/27/01 1/10/03 
target during a write cycle. 
PCI25 1 Incorrect address or write data is driven on the PCI bus during a DAC transfer. 11/15/01 1/10/03 
A parity error generated by outbound PCI reads cannot be masked by the 
PCI_26 5 PCICO_CMD[PER] bit. 3/21/02 8/8/02 
PCI 27 3 The internal PCI arbiter unfairly arbitrates when a master removes its request 9/24/02 10/23/02 
before the transfer. 
PLB 4 3 Incorrect data may be stored in the PLBO_ACR during a DCR read after DCR 8/21/04 8/21/04 
write sequence. 
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Errata 


Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 
Design Note Summary 


Table 2. Design Note Summary 


Date First 
Item Description Docu- rene 
mented P 
When the processor is not powered (i.e., Vdd and OVdd = 0), additional precau- 
d tions are needed if the IIC SDA and SCL are powered. 12/10/99 | 12/10/99 
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Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 
CPU_121 ‘The iccci instruction may errantly cause a Data TLB Exception. 
Category: 5 

Overview: 


When data-side relocation (data address translation) is enabled (MSR[DR] = 1), an iccci instruction errantly 
attempts an access check for the associated page. Since iccci invalidates the entire instruction cache, the 
effective address it generates is unnecessary. 


Impact: 


When data-side relocation (data address translation) is enabled, the execution of an iccci may cause a Data 
TLB miss exception. 


Work-around: 


There are two possible work-arounds. Work-around 1 avoids this erratum by temporarily disabling data 
address translation. Work-around 2 describes how to handle this erratum without disabling data address 
translation. 


1. Before executing an iccci instruction, make sure the MSR[DR] is disabled. This can be done using the 
following pseudo code: 


mfmsr Rx ! Rx is a scratch reg 

andi Ry,Rx,DR_MASK ! clear MSR[DR] in scratch reg Rx 
mtmsr Ry 

isync 

iccci 0,Rx ! The address does not matter. 


mtmsr Rx 
isyne 


2. When data-side relocation is enabled, ensure that the virtual address generated by the iccci (virtual 
address = {PID, effective address (RA | 0 + RB)}) has a corresponding page in the TLB. 
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Errata 
Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 


CPU_147 __ Virtual memory marked as non-executable storage (storage attribute 
EX=0) can be loaded into the instruction cache using the icbt instruc- 
tion. 


Category: 5 
Overview: 


The icbt instruction should execute as a nop (no operation) when the effective address corresponds to a 
memory page marked as non-executable. Instead, an instruction cache line fill occurs when the effective 
address of the icbt instruction maps to memory region having the following three characteristics: 
1. Marked as non-executable storage (storage attribute EX = 0). 
2. Marked as cacheable (storage attribute | = 0). 
3. Access is not prohibited by a zone fault (The access control field ZSEL references a ZPR field that 
does not prohibit access). 
Impact: 
Touching data belonging to a page marked as non-executable storage into the instruction cache with the icbt 
instruction can result in unnecessary memory accesses. Note that: 
1. Memory marked as non-executable (EX = 0) cannot be executed even if loaded into the instruction 
cache. 
2. icbt instructions are not compiler generated; they are isolated to assembly routines. 
Work-around: 
1. No work-around is necessary if either: 
a. The translation from virtual to real does not change. 
b. There are no occurrences where an icbt instruction causes a cache line fill of data from a page 
marked as non-executable storage. 
2. Invalidate cache blocks (lines) loaded with data belonging to a page marked as non-executable stor- 
age. Use either an icbi or an iccci instruction. 
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Errata 
PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 


CPU_162 When in real mode, the 405 core may errantly make speculative instruc- 
tion fetches from guarded storage. 


Category: 3 
Overview: 


In real mode, if instructions (guarded storage or not) and memory mapped I/O (guarded storage) are within 
1KB of each other, it is possible for the I/O to be speculatively accessed when the instructions are executed. 


Impact: 


Memory mapped I/O (MMIO) may be speculatively accessed. An unintentional access to MMIO could result 
in a loss of data. 


Work-around: 


Maintain at least 1KB of separation between instructions and memory mapped |/O. 
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Preliminary 


CPU_197 


Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 


Incorrect real mode attributes may be used when accessing the last 


instruction in a 128 MB region. 


Category: 3 


Overview: 


When executing instructions in real mode (MSR[IR] = 0), an access to the last instruction in a 128 MB region 
uses the real mode attributes of the next consecutive 128 MB region under any of the following conditions: 


1. The last instruction in a 128 MB region contains a branch target that is non-cacheable or causes a 


cache miss. 


2. The address restored by an rfi or rfci is the last instruction in a 128 MB region and this address is 
non-cacheable or causes a cache miss. 

3. The next to the last instruction in a non-cacheable 128 MB region contains a branch which is pre- 
dicted taken but is not taken. 

4. The next to the last instruction in a non-cacheable 128 MB region contains an isync instruction. 


Note: 


1. Real mode attributes are specified by the ICCR, SUOR, and SLER registers. 

2. All 128 MB regions have the same storage attributes after reset. Therefore, a branch instruction 
at the reset vector OXFFFFFFFC is not affected by this erratum after a core, chip, or system reset. 

3. In real mode, the storage regions wrap making the last storage region (OxF8000000 - 
OxFFFFFFFF) and the first storage region (OxO0000000 - OxO7FFFFFF) consecutive. 


Impact: 


The table below lists the impact of encountering one of the conditions listed above. The first column contains 
the real mode storage attribute of the 128 MB region being accessed and the second column contains the 
real mode storage attribute of the next consecutive 128 MB region. 


Table 3. Description of Impact for Item CPU_197 


Request from 
First Region 


Request assumes 
the attribute of 
Second Region 


Impact 


Non-cacheable 


Cacheable 


An instruction cache line fill from the non-cacheable storage region may occur. 


Cacheable Non-cacheable A desired instruction cache line fill from the cacheable storage region may not occur. 

Big Endian Little Endian The request from the big endian storage region is treated as little endian storage. A 
program exception may be generated, or an incorrect instruction may be executed. 

Little Endian Big Endian The request from the little endian storage region is treated as big endian storage. A 


program exception or machine check exception may be generated. 


Non-compressed 
Storage Region 


Compressed Storage 
Region 


The request from the non-compressed storage region is treated as compressed 
storage. A program exception may be generated. 


Compressed Storage 
Region 


Non-compressed 
Storage Region 


The request from the compressed storage region is treated as non-compressed 
storage. A program exception may be generated. 
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Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 
CPU_197 Continued 


Work-around: 
1. No work-around is required if any of the following apply: 
a. Code does not exist in the last two word locations of a 128 MB region. 
b. The real mode storage attributes of any 128 MB region containing executable code are identical 
to the attributes for the next contiguous 128 MB region. 
c. The last two words of a 128 MB region are only accessed while in virtual mode (MSR[IR] = 1). 

2. Do not place code in the last word locations of a 128 MB region. 

3. When performing a soft reset, branch directly to the entry point of the application code. Do not branch 
to the reset vector (OxFFFFFFFC). Unlike a core, chip or system reset, a soft reset does not guaran- 
tee that all 128 MB aligned regions have the same storage attributes. The branch at the reset vector 
in the last storage region (OxF8000000 - OxFFFFFFFF) will obtain the storage attributes of the first 
storage region (0x00000000 - OxO7FFFFFF). If these storage attributes differ, unexpected results are 
possible. 


405xx_600_errata_.fm.6.0.0 
Page 8 May 15, 2003 


Errata 


Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 


CPU_208 _ icbt instructions executed with data relocation enabled may cause 
incorrect instruction execution if the icbt misses in the UTLB or does 
not have permission to access the page. 


Category: 1 
Overview: 


icbt instructions executed with data relocation enabled (MSR[DR] = 1) may cause incorrect instruction execu- 
tion if the icbt misses in the UTLB or does not have permission to access the page. 
For the icbt to cause the instruction cache to deliver incorrect instructions to the fetcher a number of events 
must line up. 
Conditions: 
1. Data relocation is enabled (MSR[DR] = 1). 
2. Either condition 2a or 2b is true. 
a. The TLB page referenced by the icbt instruction is not found in the UTLB. 
b. The TLB page referenced by the icbt instruction is marked protected by its ZPR settings. 

3. A cache line fill completes while the execute logic is requesting the instruction cache unit to perform 
an icbt. 

4. The fetcher has to be requesting an address for a new cache line followed by a request for the previ- 
ous cache line. This condition occurs when the fetcher re-requests data thrown away because there 
was no room in the fetch queue. 

5. In the same cycle as conditions 3 and 4, the icbt must be presented to the instruction cache. The 
instruction cache must not accept the fetch request this cycle, but does accept the icbt. 


Impact: 
An incorrect instruction may be executed after execution of an icbt instruction. 


Note, this erratum does not affect compiler generated code. The icbt instruction is not a compiler generated 
instruction. 


Work-around: 
Perform one of the following: 
1. Ensure data relocation is disabled (MSR[DR] = 0) when executing an icbt instruction. 


or 


2. When data relocation is enabled, ensure the TLB page referenced by an icbt instruction is in the 
UTLB and not protected by access control settings. 


or 


3. When data relocation is enabled, execute an isync instruction after every icbt instruction. 
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Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 
CPU_213 Incorrect data may be flushed from the data cache. 

Category: 3 

Overview: 


The CoreConnect architecture based PPC405EP consists of masters and slaves interconnected via the 
Processor Local Bus (PLB). The PPC405 CPU features separate PLB master interfaces for the instruction 
cache unit (ICU) and the data cache unit (DCU). Any CPU load, store, or data cache control instruction may 
result in the CPU issuing one or more transactions through its DCU PLB interface. Whether or not a given 
data operation results in a PLB transaction depends on factors including the cacheability of the referenced 
address and, in the case of a cacheable access, the state of the data cache. Once the DCU initiates a PLB 
read or write request the transaction proceeds with timing that is dependent on both the PLB slave respon- 
sible for servicing the given address and PLB activity that may be occurring between other masters and 
slaves. If the PPC405 DCU interface performs the following specific sequence of PLB operations incorrect 
data may be flushed from the data cache: 


1. Data cache flush of line1 (line write): This flush is a pre-conditioning operation and is not tightly cou- 
pled with the sequence of operations defined by steps 2-5. It is only required that this flush be the last 
data side write to the PLB prior to steps 2-5. 

2. Data cache fill of line2 (line read): This fill replaces a dirty line and causes the flush in step 5. 

3. Data cache fill of line3 (line read): This fill is to a different congruence class than the line2 data cache 
fill. It may or may not cause data to be replaced or flushed. 

4. Non-cacheable or write-through write of word4 (word, halfword or byte write): The timing of the 
request on the PLB for this write must occur within a narrow window immediately after the CPU 
receives the last data item from the data cache fill of line3. 

5. Data cache flush of line2 (line write): This flush is due to the data cache fill of line2 in step 2. The data 
written to memory is incorrect. 


For this erratum to occur the PLB slave servicing the data cache fill of line3 must return the cache line data in 
four consecutive PLB cycles. Since the PLB data buses are 64-bits wide and all of the slaves in the 
PPC405EP feature 32-bit external buses, line fill data is in most cases returned every other PLB cycle. For 
data to be returned in consecutive PLB cycles the slave must have accepted the line fill request from the CPU 
as a pipelined transfer, and read and buffered the line contents from external memory while at the same time 
another PLB transaction between a different master and slave maintained ownership of the on-chip PLB read 
data bus. 


An instruction sequence that can cause the above series of data side PLB operations is as follows: 


1. A load or store instruction that misses in the data cache and causes a fill to a line with the Least 
Recently Used (LRU) tag pointing to a valid dirty line, or a dcbf to a line with valid dirty data: This 
instruction causes the flush of line1. 

2. A load or store instruction that misses in the data cache and causes a line fill to a line with its LRU 
pointing to a valid dirty line: This instruction causes both the fill of line2 and a subsequent flush of the 
dirty contents of line2 that were replaced by the fill. 

3. A store instruction that misses in the data cache and causes a line fill: This instruction causes the fill 
of line3 and may or may not result in a line flush. 

4. A store instruction to a memory address designated as either non-cacheable or write-through: This 
instruction causes the non-cacheable write of word4. 

5. A load instruction requiring data from either or both of the last two 64-bit doublewords returned for the 
cache line fill of line3. This load does not cause a PLB operation, but is required to create the condi- 
tions necessary to cause this erratum. 
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Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 
CPU_213 Continued 


These instructions need not execute with a particular timing relative to each other. Rather, they may be sepa- 
rated by other unrelated instructions and operations including branches, interrupts, instruction cache misses, 
and additional loads or stores that hit in the data cache. 


Impact: 
Incorrect data may be flushed (written) to memory from the data cache. 
Work-around: 


Perform one of the following work-arounds: 

* Set CCRO reserved bits 1 and 3. When these bits are set and there is a line fill pending or in progress 
for a data cache miss the data cache is prevented from servicing other CPU load or store requests. 
Because this work-around blocks data cache accesses during line fills it may affect performance. 

¢ Mark all data memory as write-through using the DCWR register or W storage attribute of each TLB 
entry. 
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PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 
EMAC_5 The EMAC constantly transmits a preamble pattern on the MIl interface. 
Category: 4 

Overview: 


The minimum value specified for the TLR (EMACO_TMR1[TLR]) is wrong. The correct equation is: 
min(TLR) = (MAL Burst Limit / 2) + 1 

Since the MAL Burst Limit is 16, the correct minimum value for TLR is 9. 

Impact: 


An incorrect TLR setting (below the minimum) can cause the EMAC to constantly transmit a preamble pattern 
on the MIl interface which blocks anything else from being transmit. This error does not generate an error 
indication such as an interrupt or a status bit. 


Work-around: 
Set the TLR value to 9 (EMACO_TMR1[TLR]=9). 
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Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 

EMAC_7 Signal Quality Error (SQE) occasionally reported incorrectly during SQE 
test. 

Category: 5 

Overview: 


Occasionally while running the Signal Quality Error (SQE) test, errors may be reported even though none 
have occurred. The SQE test is only used when operating an MIl interface at 10Mbs in half-duplex mode, and 
is used to verify the Collision Detect logic in the PHY is operating properly. 


Impact: 

This is a minor problem and has no affect on data transfers with the EMAC. 
Work-around: 

Disable the SQE test in the EMAC. 
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PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 
EMAC_8 Soft Reset may not reset all logic in the EMAC 

Category: 5 

Overview: 

Soft Reset (EMACO_MRO[SRST]) may not reset all logic in the EMAC. 

Impact: 


Once Soft Reset has completed, and the receive channel is re-enabled, an extra data double word may be 
added at the beginning of the first received packet without any bad status indication on this packet when 
forwarded to the MAL. 


Work-around: 


Before Soft Resetting the EMAC, first disable the receive channel (EMACO_MRO[RXE]=0), then wait for the 
RX MAC ldle bit to be set (EMACO_MRO[RXI]=1). Once idle, enable the Soft Reset bit 
(EMACO_MRO[SRST]=1). 
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Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 
EMAC_9 Integrated Flow Control Mechanism may not function correctly 
Category: 4 

Overview: 


The integrated flow control mechanism is used only in Full-duplex mode in order to avoid receive FIFO 
overrun. Two watermarks are set on the receive FIFO. When the high watermark is crossed upwards, an 
urgent pause packet is internally assembled and transmitted causing the other end’s transmitter to stop. 
When the low watermark is crossed downwards, a zero pause packet is internally assembled and trans- 
mitted, thus causing the other end to resume transmission. 


There are three problems with the integrated flow control mechanism: 


1. Ifarequest is issued, and in the meanwhile the opposite watermark is crossed, the request initiator could 
take the request back. A request is taken back by de-asserting the request signal without waiting for 
acknowledge. This condition can lead to a deadlock in the handshake protocol, since the request initiator 
cannot know if the transmitter received the request (or if it is going to acknowledge the request). 


2. The integrated flow control mechanism cannot issue two consecutive urgent pause packet requests. 


3. When a request for a zero pause packet is issued, and until an acknowledge is accepted, the receive 
FIFO can theoretically reach the high watermark. The issue pause mechanism is not aware of this high 
watermark crossing, and thus does not send an urgent pause packet. 


Impact: 
The impact of the three problems list above is as follows: 


1. Total failure of the issue pause mechanism preventing future pause control frames from being issued as a 
response to watermark crossings. 


2. FIFO overflow - A user may want to set the Pause Timer Register to a small value that causes only a 
short stop, which would not necessarily cause the receive FIFO to fall below the low watermark. 


3. FIFO overflow - The FIFO overflow occurs because the high watermark crossing does not cause an 
immediate request for non-zero pause packet transmission. 


Work-around: 
No work-around is available. Integrated Flow Control should be disabled (EMACO_MR1[EIFC]=0). 
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PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 


EMAC_10 Octet Counter Registers may not record an accurate count 
Category: 4 
Overview: 


The Transmitted Octet Count Register (EMACO_OCTX) and Received Octet Count Register 
(EMACO_OCRX) contain the total number of bytes transmitted and received respectively on the media 
(including bad packets). After a packet is transmitted or received, the transmitter or receiver sends the 
number of frame bytes to the count register logic, where it is added to the proper counter register. Since the 
transmit and receive logic are on a different clock domain from the register logic, synchronization across the 
clock boundary is necessary. In the process of crossing the clock boundary, the count from the transmitter or 
receiver may be incorrectly sampled, therefore, causing the counter registers to record inaccurate values. 


Impact: 

The EMACO_OCTX and EMACO_OCRxX registers may not contain an accurate count. 
Work-around: 

No work-around is available. 
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Preliminary PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 
PCI_18 Executing code from PCI address space may hang the CPU. 

Category: 3 

Overview: 


As with all high-performance processors, the PPC405 CPU features an instruction pipeline designed to 
provide the execution unit with a steady stream of instructions. To optimize throughput, the instruction fetcher 
attempts to keep the pipeline full by requesting instructions along the most probable path of code execution. 
Whenever an instruction fetch cannot be fulfilled by the instruction cache, either a 4-word or 8-word line fill 
request is forwarded via the on-chip Processor Local Bus (PLB) to either the SDRAM, PCI, or peripheral bus 
controller. In the case of instruction fetches from PCI address space, the PCI controller obtains and internally 
buffers the requested instructions from the PCI target before returning them to the CPU. If during this period 
of time an instruction such as a conditional branch or an interrupt alters the code flow such that the pending 
instruction fetch from PCI address space is no longer necessary, the CPU may abort the transfer. 


Impact: 


If the CPU aborts an instruction fetch from PCI address space and then subsequently performs a data read 
from PCI address space, the read may hang the PLB bus. This hang condition will persist until the CPU 
fetches another instruction from PCI address space. 


Work-around: 


If the CPU is not fetching instructions from PCI address space no work-around is required. Otherwise, ensure 
that the CPU is the only master in the PPC405EP accessing PCI address space and do all of the following: 


1. Completely disable instruction caching. If operating in real mode, MSR[IR] = 0, set ICCR = O. If run- 
ning in virtual mode, MSR[IR] = 1, ensure that all TLB entries that allow execution, TLBLO[EX] = 1, 
also inhibit instruction caching: TLBLO[I] = 0. 

2. Program CCRO[24] = 1. Setting this undocumented bit ensures that the CPU cannot continuously sat- 
isfy instruction requests from the instruction cache fill buffer. 

3. Program PCILO_PMMnHA = 0x0 for all PLB to PCI mappings containing executable code. This pre- 
vents the PCI Bridge from generating dual address cycles on the PCI bus. 


Items 1 & 2 in this work-around ensure that any CPU data request from PCI address space will be followed by 
an instruction fetch, thus preventing the PCI Bridge from becoming stuck in a hang condition. Following an 
aborted instruction fetch, the PCI Bridge may fail to complete a delayed read. Therefore, the PCI target 
providing instructions to the PPC405EP may be unresponsive until its delayed read discard timer expires 
after 215 PCI clocks. Also, the target may detect this situation as an error condition. The system must be 
tolerant of these events. 


Note: If the PCI target is another PPC405EP, its delayed read discard timer will expire, allowing for- 
ward progress, and no error will be detected. 


Since executing directly from PCI address space is relatively slow, and because data in PCI address space 
cannot be cached, (the PCI Bridge does not support cache line write operations) it is highly recommended 
that systems boot from PCI and load their application into SDRAM memory. Boot code executing from PCI 
space should set CCRO[24] = 1 immediately after the branch from address OxFFFFFFFC. Once the load 
process completes and execution is from SDRAM address space, enable instruction caching and clear 
CCRO[24]. 
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PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) Preliminary 

PCI_24 The PCI Bridge Controller does not detect a parity error (PCIPErr) 
asserted by a target during a write cycle. 

Category: 1 


Overview: 


The PCI Bridge Controller fails to detect a parity error (PCIPErr) asserted by a target during a write cycle 
under the following conditions: 


1. The PCI Bridge is operating in Asynchronous Mode. 

2. The PCI Bridge is running an outbound (PLB-to-PCl) write. 

3. The PCI target asserts PCIPErr in response to detecting a data parity error. 
4 

5 


. The parity error is for the last beat of a burst or for a single beat. 
. The PCIClk frequency is within the following range: 0.7*SyncPClClock < PCICIk < 1.1*SyncPClClock 


PCICIk ranges affected by this erratum for typical clock configurations: 


¢ PLB Clk = 100MHz, SyncPClClock = 50MHz, 35MHz < PCICIk < 51MHz 
¢ PLB Clk = 133MHz, SyncPClClock = 66.7MHz, 46.7MHz < PCIClk < 66.7MHz 
¢ PLB Clk = 133MHz, SyncPClClock = 44.4MHz, 31.1MHz < PCIClk < 46MHz 


Note: The SyncPClClock is an internal clock derived from the PLB Clk and PCIClk is supplied by the 
PCI bus. 

Impact: 

A parity error may not be detected during a write cycle. 

Work-around: 


Select a PCICIk outside the failing frequency range such that PCICIk < 0.7*SyncPClClock or PCICIk > 
1.1*SyncPClClock. 
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PCI_25 Incorrect address or write data is driven on the PCI bus during a DAC 
transfer. 

Category: 1 

Overview: 


When the PCI Bridge Controller is the initiator of a DAC (Dual Address Cycle) transfer in Asynchronous 
Mode, it may drive incorrect address and/or write data values on the PCI bus. This error can occur if the 
internal SyncPClClock and the externally supplied PCICIk have clock periods within +2ns of one another. The 
following are PCICIk frequency ranges for typical clock configurations that are affected by this erratum: 


* PLB Clk = 100MHz, Sync PCI Clk = 33.3MHz, 31MHz < PCICIk < 36MHz 

« PLB Clk = 100MHz, Sync PCI Clk = 50MHz, 45MHz < PCICIk < 55MHz 

¢ PLB Clk = 133MHz, Sync PCI Clk = 66.7MHz, 59MHz < PCICIk < 66.7MHz 
Note: 


(1) DAC cycles are used to address PCI targets in the address space above 4 Gigabytes. 
(2) The SyncPClClock is an internal clock derived from the PLB Clk and the PCIClk is supplied by 
the PCI bus. 


Impact: 
Address and data values driven on the PCI bus are not reliable during a DAC transfer. 
Work-around: 


Use one of the following clock configurations: PLB Clk/SyncPCIClock/PCICIk = 100MHz/100MHz/66MHz, 
100MHz/50MH2/33MHz, 133MHz/44MHz/33MHz. 
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PCI_26 A parity error generated by an outbound PCI read cannot be masked by 
the PCICO_CMD[PER] bit. 

Category: 4 

Overview: 


The Parity Error Response bit (PCICO_CMD/PER]) determines whether a PCI error is recorded by the PLB 
Bus Error Assertion Event status bit (PCICO_ERRSTS[MEAE]) and reported to the PLB master. However, the 
PCICO_CMD[PER] does not reliably mask a parity error generated by an outbound PCI read. (Outbound 
traffic is generated when the PCI Bridge is a PLB slave and a PCI Master.) The table below list all scenarios 
where PCICO_CMD/PER] fails to correctly mask outbound parity errors. 


Note: The PCICO_CMD/[PER] correctly masks the PCICO_STATUS[DPE] for outbound reads. 
Table 4. List all affected PCICO_CMD[PER] and PCICO_ERREN[MEAE] bit combinations 


Error 
pol data bus PCICO_CMD[PER] PCICO_STATUS[DPE] | PCICO_ERREN[MEAE] |PCICO_LERRSTS[MEAE]| Reported to 
Parity Error 
PLB Master 
Outbound ed ba ae No error 
Read 0 0 0 regardless of the reported 
PCICO_CMD[PER] 
May report an error 
ae 0 0 1 regardless of the i sie - 
PCICO_CMD[PER] 
Outbound May not report 
Read 1 1 1 May not report an error ai error 
Impact: 


Outbound read parity errors are unreliably masked by the PCICO_CMD/[PER] bit. 


Work-around: 


1. To prevent a PCI Parity error from being reported to a PLB master, mask PCI parity errors and disable 
error reporting by setting PCICO_CMD[PER]=0 and PCICO_ERREN[MEAE]=0. Note, clearing the 
PLB Error Assertion Enable (PCICO_ERREN[MEAE]=0) prevents any bus error from being reported 
to a PLB master. 

2. There is no work-around to guarantee a PCI parity error is reported to a PLB master when PCI parity 
errors are unmasked and error reporting is enabled, PCICO_CMD[PER]=1 and 
PCICO_ERRSTS[MEAE]=1. 
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PCI_27 


Category: 3 


Overview: 


Errata 


PPC405EP Rev 1.1 (IBM25PPC405EP-3GBxxxCx) 


The internal PCI arbiter unfairly arbitrates when a master removes its 
request before the transfer. 


The internal PCI arbiter does not track fairness in the situation given in Table 5 and described below. 


Cycle 1. 


Cycle 2. 
Cycle 4. 
Cycle 5. 


Cycle 6. 
Cycle 7. 
Cycle 9. 
Cycle 11. 


Cycle 13. 


Master A performs a read arbitration request (via one of PCIReq1:5) to the PPC405EP 
(inbound). 

Master A is granted the bus. 

Master B performs a read arbitration request to the PPC405EP (inbound). 

The PPC405EP retries the request from Master A (by asserting PCIStop and deasserting 
PCITRDY). The read is handled as a delayed transaction. 

When Master A is retried, Master B deasserts its read request for one clock cycle. 
Master B is granted the bus and begins a read cycle on the bus. 

Master B is retried by the PPC405EP. 

One PCI clock cycle after the retry in cycle 9, Master B detects the bus is idle with the grant 
going away and immediately starts a new read cycle. 

Master B is again retried because the PPC405EP has read data available for Master A. 


Cycles 11 through 14 repeat. With the early removal of the Master B read request in cycle 10, the arbiter 
fairness algorithm does not block Master B and Master A does not receive grant long enough to obtain 


the bus. 
Table 5. PCI Tenure Sequence demonstrating erratum PCI_27 
Cycle Master REQ_A = GNTA | REQB_~ GNTB | FRAME IRDY DEVSEL | STOP 
1 0 1 1 1 1 1 1 1 
2 0 0 1 1 1 1 1 1 
3 0 0 1 1 0 1 1 1 
4 0 0 0 1 1 0 1 1 
A 

5 0 1 0 0 1 0 0 0 
6 1 1 1 0 1 1 1 1 
7 1 1 0 1 0 1 1 1 
8 0 1 0 0 1 0 1 1 
9 s 0 1 0 0 1 0 0 0 
10 0 1 1 0 1 1 1 1 
11 0 1 1 1 0 1 1 1 
12 0 0 0 1 1 0 1 1 
13 . 0 1 0 0 1 0 0 0 
14 0 1 1 0 1 1 1 1 
15 0 1 1 1 0 1 1 1 
16 0 0 0 1 1 0 1 1 
17 : 0 1 0 0 1 0 0 0 
18 0 1 1 0 1 1 1 1 
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PCI_27 Continued 


Master B removes its read request in cycle 10 before the arbiter records which master received the grant. 
Subsequent requests by Master B are treated as its first. The arbiter repeatedly grants the bus to Master B 
and does not give Master A an opportunity to complete the delayed read. This situation continues until either 
the delayed-read discard timer expires or the PPC405EP generates an outbound request. The delayed-read 
discard timer expires after 2'5 PCI clocks. 


Impact: 

The PCI arbiter repeatedly grants the bus to only one master resulting in a live lock condition. 
Work-around: 

Perform one of the following if a PC] Master behaves as Master B described in the overview: 


1. Delay the PCIReq from the PCI Master by one PCI clock by inserting a flip-flop between PCI Master 
PCIReq pin and the PCI arbiter (arb_req# = flip_flop_Q; flip_flop_D = master_req#, flip flop CLK = 
PCI_CLk) 


If timing can be met, the output of the flip-flop can additionally be AND’ed with the input for better per- 
formance (arb_req# = flip_flop_Q & flip_flop_D; flip_flop_D = master_req#, flip_flop_ CLK =PCI_CLKk) 


2. Use an external PCI arbiter. 
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PLB_4 Incorrect data may be stored in the PLBO_ACR during a DCR read after 
DCR write sequence. 

Category: 3 

Overview: 


If a DCR write operation (mtdcr) to the PLB Arbiter Control Register (PLBO_ACR) is immediately followed by 
a DCR read operation (mfdcr) of the same register, the PLBO_ACR will latch in Os instead of the intended 
DCR write data. 


Impact: 
Incorrect data may be stored in the PLBO_ACR. 
Work-around: 


Do not read the PLBO_ACR register immediately after writing it. Separate a DCR read from a DCR write of 
the PLBO_ACR with a DCR read of any register other than PLBO_ACR. 
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Design Notes: 


1. When the processor is not powered (i.e., Vdd and OVdd = 0), additional precautions are needed if the IIC 
SDA and SCL are powered. Under this circumstance, the processor is in a high-impedance state and 
may be damaged and/or experience a degradation in reliability. (Note: The IIC SDA and SCL I/Os are 5V 
tolerant which implies that the voltage on these I/Os may be as high as 5.5V.) The following critical items 
must be considered: 


a. If the input voltage to the PPC405xx/NPe405x exceeds the ESD protection diode drop and is sup- 
plied with a current in excess of 147mA, the IIC SDA and SCL I/Os will be permanently damaged. 
i (Vsource — (4*0.8)/(Rsource) 
ii Vsource = source voltage = 5.5V maximum 
iii RSource = source resistance = Pull-up Resistor for 0.147 = (5.5 — 3.2)/Rsource or Rsource = 
2.3/0.147 = 15.65 ohms (minimum) 


Raising the value from this minimum of 15.65 ohms and/or reducing Vsource from 5.5 V will give 
added margins of safety against the I/O being permanently damaged. 

b. A sustained (i.e. several hours) maximum current greater than 8.1 mA will weaken or degrade the reli- 
ability of the IIC SDA and SCL I/Os. To improve reliability choose a pull-up resistor, Rsource, greater 
than 284 ohms, 0.0081 = (5.5 — 3.2)/Rsource = 284 ohms. (The recommended value for Rsource in 
the processor data sheet is 3K ohms. 284 ohms is the minimum for protection against damaging cur- 
rents and 3K ohms is the maximum that guarantees a logic 1/high with a pull-up.) 

c. Use a series resistor to ensure that the voltages applied to SDA and SCL inputs do not exceed a 3.2 
V drop across the ESD diodes when Vdd = OVdd = 0 V. The choice of series resistor depends on the 
pull-up resistor used and the required voltage levels at the inputs of the other devices on the IIC bus 
(Vih, min = 2.4 V). 
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